# INDEX

| 1. System Process                               | 2  |
|-------------------------------------------------|----|
| 1.1 Process Overview                            | 2  |
| 1.2 Process of chip (color bar)                 | 3  |
| 1.3 Process of chip (VI)                        | 4  |
| 2. Status Registers (BASE)                      | 7  |
| 2.1 System Status                               | 7  |
| 2.2 Broadcast Status                            | 9  |
| 3.AV Control Registers (Stream Registers)       | 11 |
| 3.1 Registers for Video Input Settings          | 11 |
| 3.2 Registers for AV Encoder Settings           | 13 |
| 4. MUXER register                               | 15 |
| 4.1 Mux Related Settings                        | 15 |
| 5. PSI Register                                 | 16 |
| 5.1 Playload Buffer Register                    | 16 |
| 5.2 PSI Pure Mode                               | 16 |
| 5.3 Private PSI table                           | 17 |
| 6. Modulator Register                           | 18 |
| 6.1 Modulator Related Settings                  | 18 |
| 6.2 DVB-T Settings                              | 20 |
| 6.3 DVB-C (J83A) Settings                       | 20 |
| 6.4 ATSC (8VSB) Settings                        | 21 |
| 6.5 Clear QAM (J83.B) Settings                  | 21 |
| 6.6 DTMB Settings                               | 21 |
| 6.7 ISDB-T Settings                             | 22 |
| 6.8 J83.C Settings                              | 24 |
| 6.9 DVB-T2 Settings                             | 24 |
| 7. Broadcast Related Registers                  | 27 |
| 7.1 General Settings                            | 27 |
| 7.2 RF Related Settings (For VATEK R2 Control)  | 28 |
| Appendix                                        | 29 |
| A. Register PSI/SI table by using PSI PURE mode | 29 |
| B. Insert PSI/SI table by using PSI PURE mode   | 31 |
| C. RF start flow (for VATek R2)                 | 32 |

# 1. System Process

# 1.1 Process Overview



# 1.2 Process of chip (color bar)

You can use color bar as input source without input extra source.



續下頁



# 1.3 Process of chip (VI)

To using VI mode, you need to finish setting input PHY at the front end.



續下頁



續下頁



# 2. Status Registers (BASE)

# 2.1 System Status

0x20 - HALREG\_SYS\_STATUS\_0: System Status Register 0

| Bit # | Type | Value      | Name                      |
|-------|------|------------|---------------------------|
|       | R    | 0xFF000001 | SYS_STATUS_IDLE:          |
|       | R    | 0xFF000002 | SYS_STATUS_RUN:           |
|       | R    | 0xFF000085 | SYS_STATUS_LOADER_FAIL    |
| 0~31  | R    | 0xFF000086 | SYS_STATUS_SERVICE_FAIL   |
|       | R    | 0xFF000088 | SYS_STATUS_EXCEPTION_FAIL |
|       | R    | 0xFF00008E | SYS_STATUS_BADSTATUS      |
|       | R    | 0xFF00008F | SYS_STATUS_UNKNOWN_FAIL   |

0x23 - HALREG\_SYS\_ERRCODE: System Error Code Register

| Bit # | Туре | Value      | Name                 |
|-------|------|------------|----------------------|
|       | R    | 0x80000001 | SYS_ERRCODE_INIT     |
|       | R    | 0x80010001 | LOADER_ERRCODE_NOAPP |
| 0~31  | R    | 0x80010002 | LOADER_ERRCODE_CRC32 |
|       | R    | 0x80010003 | LOADER_ERRCODE_HW    |
|       | R    | 0x80020001 | SERVICE_INIT_FAIL    |

# 0x24 - HALREG\_CHIP\_ID: CHIP ID Register

| Bit # | Туре | Value      | Name               |
|-------|------|------------|--------------------|
|       | R    | 0x00010100 | HAL_CHIPID_A1      |
|       | R    | 0x00010300 | HAL_CHIPID_A3      |
|       | R    | 0x00020100 | HAL_CHIPID_B1      |
| 0~31  | R    | 0x00020200 | HAL_CHIPID_B2      |
|       | R    | 0x00020201 | HAL_CHIPID_B2_PLUS |
|       | R    | 0x00020300 | HAL_CHIPID_B3      |
|       | R    | 0x00020301 | HAL_CHIPID_B3_PLUS |

# 0x25 - HALREG\_FW\_VER: Firmware Version Register

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | R    |       |      |

## 0x26 - HALREG\_SERVICE\_MODE: Service Mode Register

| Bit # | Туре | Value      | Name                  |
|-------|------|------------|-----------------------|
|       | R    | 0xFF000001 | SERVICE_TAG_RESCUE    |
| 0~31  | R    | 0xF8000001 | SERVICE_TAG_BROADCAST |
|       | R    | 0xF8000002 | SERVICE_TAG_TRANSFORM |

# 0x27 - HALREG\_PERIPHERAL\_EN: Peripheral Switch Register

| Bit # | Туре | Value      | Name                       |
|-------|------|------------|----------------------------|
| 0     |      | Reserved   |                            |
| 1     | R    | 0x00000002 | PERIPHERAL_FINTEKR2        |
| 2~15  |      | Reserved   |                            |
| 16    | R    | 0x00010000 | PERIPHERAL_EP9555E         |
| 17    | R    | 0x00000100 | PERIPHERAL_USBBULK         |
| 18    | R    | 0x00000200 | PERIPHERAL_AUXSTREAM_USB   |
| 19    | R    | 0x00000400 | PERIPHERAL_AUXSTREAM_FLASH |
| 20    | R    | 0x00000800 | PERIPHERAL_AUXSTREAM_TSIN  |
| 21    | R    | 0x01000000 | PERIPHERAL_CALIBRATION     |
| 22    | R    | 0x70000000 | PERIPHERAL_HWID_MASK       |
| 23~31 |      | Reserved   |                            |

# **0x28 - HALREG\_INPUT\_SUPPORT:** Media Source Register

| Bit # | Туре | Value      | Name          |
|-------|------|------------|---------------|
| 0     | R    | 0x0000001  | INPUT_EN_TEST |
| 1     | R    | 0x00000002 | INPUT_EN_USB  |
| 2     | R    | 0x0000004  | INPUT_EN_TS   |

| 3     | R | 0x00000008 | INPUT_EN_ENC        |
|-------|---|------------|---------------------|
| 4     | R | 0x0000010  | VENC_EN_MPEG2       |
| 5     | R | 0x00000020 | VENC_EN_H264        |
| 7     |   | Reserved   |                     |
| 8     | R | 0x00000100 | VENC_EN_FULLHD      |
| 9~11  |   | Reserved   |                     |
| 12    | R | 0x00001000 | AENC_EN_MP1_L2      |
| 13    | R | 0x00002000 | AENC_EN_AAC_LC_ADTS |
| 14    | R | 0x00004000 | AENC_EN_AC_3        |
| 15    | R | 0x00008000 | AENC_EN_AAC_LC_LATM |
| 20    | R | 0x00100000 | TEST_EN_HW          |
| 21    | R | 0x00200000 | TEST_EN_REMUX       |
| 22~31 |   | Reserved   |                     |

# 0x29 - HALREG\_OUTPUT\_SUPPORT: Output Mode Register

| Bit # | Туре | Value      | Name               |
|-------|------|------------|--------------------|
| 0     | R    | 0x0000001  | OUTPUT_EN_MOD      |
| 1     | R    | 0x00000002 | OUTPUT_EN_SINEWAVE |
| 2     | R    | 0x0000004  | OUTPUT_EN_TS       |
| 3     | R    | 0x00000008 | OUTPUT_EN_USB      |
| 5~7   |      | Reserved   |                    |
| 8     | R    | 0x00000100 | MOD_EN_DVB_T       |
| 9     | R    | 0x00000200 | MOD_EN_J83_A       |
| 10    | R    | 0x00000400 | MOD_EN_ATSC        |
| 11    | R    | 0x00000800 | MOD_EN_J83_B       |
| 12    | R    | 0x00001000 | MOD_EN_DTMB        |
| 13    | R    | 0x00002000 | MOD_EN_ISDB_T      |
| 14    | R    | 0x00004000 | MOD_EN_J83_C       |
| 15    | R    | 0x00008000 | MOD_EN_DVB_T2      |
| 16    | R    | 0x00005F00 | MOD_EN_BASE        |
| 17~31 | -    | Reserved   |                    |

# 2.2 Broadcast Status

# **0x620 - HALREG\_BCINFO\_STREAM:** Enable stream mode

| Bit # | Туре | Value    | Name |
|-------|------|----------|------|
| 3~31  | W    | Reserved |      |

# **0x621 - HALREG\_BCINFO\_OUTPUT:** Enable output mode

| Bit # | Туре | Value    | Name |
|-------|------|----------|------|
| 1~31  | W    | Reserved |      |

#### **0x622 - HALREG\_BCINFO\_MODRATE:** Show output bitrate of

#### MODULATOR.

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | R    |       |      |

#### **0x623 - HALREG\_BCINFO\_MUXRATE:** Show output bitrate of MUX

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | R    |       |      |

#### **0x624 - HALREG\_BCINFO\_STATUS:** Broadcast Status Register

| Bit # | Туре | Value      | Name                    |
|-------|------|------------|-------------------------|
|       | R    | 0x00000000 | BCSTATUS_IDLE           |
| 0.1   | R    | 0x00000001 | BCSTATUS_WAIT_SOURCE    |
| 0~1   | R    | 0x00000002 | BCSTATUS_BROADCAST      |
|       | R    | 0x00000003 | BCSTATUS_FINISH         |
| 2~31  |      | Reserved   |                         |
|       | R    | 0x80000000 | BCSTATUS_FAIL_UNKNOWN   |
|       | R    | 0x80000001 | BCSTATUS_FAIL_SOURCE    |
|       | R    | 0x80000002 | BCSTATUS_FAIL_TIMEOUT   |
|       | R    | 0x80000003 | BCSTATUS_FAIL_CODECDROP |
| 32    | R    | 0x80000004 | BCSTATUS_FAIL_BUFFER    |
|       | R    | 0x80000005 | BCSTATUS_FAIL_MUXER     |
|       | R    | 0x80000006 | BCSTATUS_FAIL_ENCODE    |
|       | R    | 0x80000007 | BCSTATUS_FAIL_MEDIA     |
|       | R    | 0x80000008 | BCSTATUS_FAIL_DEMUX     |

#### 0x625 - HALREG BCINFO CURRATE: Show real bitrate of MUX

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | R    |       |      |

## **0x626 - HALREG\_BCINFO\_DATARATE:** Show PES bitrate.

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | R    |       |      |

#### **0x627 - HALREG\_BCINFO\_QUERYBUF:** Show buffer length.

|       |      |       | <br> |
|-------|------|-------|------|
| D:4.# | T    | Value | N    |
| Bit # | Type | Value | Name |

| 0~31 | R |  |  |
|------|---|--|--|
|------|---|--|--|

# **3.AV Control Registers (Stream Registers)**

# 3.1 Registers for Video Input Settings

## 0x643 - HALREG\_VIDEO\_RESOLUTION: Video Encoder resolution

| Bit # | Туре | Value      | Name             |
|-------|------|------------|------------------|
|       | W    | 0x00000000 | RESOLUTION_480I  |
|       | W    | 0x00000001 | RESOLUTION_480P  |
|       | W    | 0x00000002 | RESOLUTION_576I  |
| 0~2   | W    | 0x00000003 | RESOLUTION_576P  |
|       | W    | 0x00000004 | RESOLUTION_720P  |
|       | W    | 0x00000005 | RESOLUTION_1080I |
|       | W    | 0x0000006  | RESOLUTION_1080P |
| 3~31  |      | Reserved   |                  |

# **0x644 - HALREG\_VIDEO\_FRAMERATE:** Video Encoder framerate

| Bit # | Туре | Value      | Name            |
|-------|------|------------|-----------------|
|       | W    | 0x00000000 | FRAMERATE_23_97 |
|       | W    | 0x00000001 | FRAMERATE_24    |
|       | W    | 0x00000002 | FRAMERATE_25    |
| 0~2   | W    | 0x00000003 | FRAMERATE_29_97 |
| 0~2   | W    | 0x00000004 | FRAMERATE_30    |
|       | W    | 0x00000005 | FRAMERATE_50    |
|       | W    | 0x00000006 | FRAMERATE_59_94 |
|       | W    | 0x00000007 | FRAMERATE_60    |
| 3~31  |      | Reserved   |                 |

## **0x645 - HALREG\_VIDEO\_ASPECTRATE:** Video Encoder aspect rate

| Bit # | Туре | Value      | Name            |
|-------|------|------------|-----------------|
| 0     | W    | 0x00000000 | ASPECTRATE_4_3  |
| 0     | W    | 0x00000001 | ASPECTRATE_16_9 |
| 1~31  |      | Reserved   |                 |

# 0x647 - HALREG\_AUDIO\_CHANNEL: Audio Encode Mode Select

#### Register

| Bit | # | Туре | Value      | Name         |
|-----|---|------|------------|--------------|
| 0~2 | 2 | W    | 0x00000000 | CHANNEL_MUTE |

|  |      | W | 0x00000001 | CHANNEL_STEREO        |
|--|------|---|------------|-----------------------|
|  |      | W | 0x00000002 | CHANNEL_MONO_L        |
|  |      | W | 0x00000003 | CHANNEL_MONO_R        |
|  |      | W | 0x00000004 | CHANNEL_STEREO_MONO_L |
|  |      | W | 0x00000005 | CHANNEL_STEREO_MONO_R |
|  | 3~31 |   | Reserved   |                       |

#### **0x648 - HALREG\_AUDIO\_SAMPLERATE:** Audio Sample Rate Register

| Bit # | Туре | Value      | Name               |
|-------|------|------------|--------------------|
|       | W    | 0x00000000 | SAMPLERATE_32KHZ   |
| 0~1   | W    | 0x0000001  | SAMPLERATE_44_1KHZ |
|       | W    | 0x00000002 | SAMPLERATE_48KHZ   |
| 3~31  |      | Reserved   |                    |

#### **0x660 - HALREG\_VI\_0\_FLAGS:** Video Interface Setup Register

| Bit # | Туре | Value      | Name              |
|-------|------|------------|-------------------|
| 0~3   |      | Reserved   |                   |
| 4     | W    | 0x0000010  | VI_BUSWIDTH_16    |
| 5     |      | Reserved   |                   |
| 6     | W    | 0x00000040 | VI_SEPARATED_SYNC |
| 7~8   |      | Reserved   |                   |
| 9     | W    | 0x00000200 | VI_CLK_INVERSE    |
| 10    | W    | 0x00000400 | VI_HSYNC_INVERSE  |
| 11    |      | Reserved   |                   |
| 12    | W    | 0x00001000 | VI_VSYNC_INVERSE  |
| 13~23 |      | Reserved   |                   |
| 24    | W    | 0x01000000 | VI_FIELDID_SIGNAL |
| 25~27 |      | Reserved   |                   |
| 28    | W    | 0x10000000 | VI_EXT_HALF_FPS   |
| 29    | W    | 0x20000000 | VI_FIELD_INVERSE  |

#### **Description**

- VI\_BUSWIDTH\_16: setting output base on PHY, default is 0. 0 is 8bits data; 1 is 16-bits data.
- VI\_SEPARATED\_SYNC: setting output base on PHY, default is 0 ∘ 0 is Embedded Sync; 1 is Separated Sync.
- VI\_CLK\_INVERSE: setting output base on PHY, default is 0. 0 is trigger at rising edge; 1 is trigger at falling edge.

- VI\_HSYNC\_INVERSE: setting output base on PHY, default is 0. 0 is Negative Polarity; 1 is Positive Polarity.
- VI\_VSYNC\_INVERSE: setting output base on PHY, default is 0. 0 is Negative Polarity; 1 is Positive Polarity •
- VI\_FIELDID\_SIGNAL: setting output base on PHY, default is 0. 0 is using Field ID pin; 1 is detecting Field ID from timing.
- VI\_EXT\_HALF\_FPS: minus half frame rate from input. 0 is disable;
   1 is enable.
- VI\_FIELD\_INVERSE: setting output base on PHY, default is 0. 0 is top field first; 1 is bottom field first.

# **0x661 - HALREG\_VI\_0\_PIXELCLOCK:** Video Input Pixel Clock Register

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

# 3.2 Registers for AV Encoder Settings

0x602 - HALREG BROADCAST STREAM: Setting stream mode

| Bit | t # | Туре | Value      | Name           |
|-----|-----|------|------------|----------------|
| C   | )   | W    | 0x00000003 | STREAM_ENCODER |
| 1   | 1   | W    | 0x00001000 | STREAM_SINE    |
| 2   | 2   | W    | 0x00001001 | STREAM_TEST    |
| 2~3 | 31  |      | Reserved   |                |

#### 0x640 - HALREG\_ENCODER\_MODE: Encoder Mode Control Register

| Bit # | Туре | Value      | Name            |
|-------|------|------------|-----------------|
| 0     | W    | 0x00000000 | ENCMOD_COLORBAR |
| 1     | W    | 0x00000001 | ENCMOD_BOOTLOGO |
| 2     | W    | 0x00000002 | ENCMOD_VI_0     |
| 3~31  |      | Reserved   |                 |

#### **Description**

- ENCMOD\_COLORBAR: use SMPTE COLORBAR to be the output.
- ENCMOD\_BOOTLOGO: use boot logo to be the output which already store in v2img firmware file by user.

ENCMOD\_VI\_0: use real input source from HDMI or CVBS interface

0x641 - HALREG\_ENCODER\_FLAGS: Encoder Mode Switch Register

| Bit # | Туре | Value      | Name                        |
|-------|------|------------|-----------------------------|
| 0     |      | Reserved   |                             |
| 1     | W    | 0x00000001 | ENC_EN_DISABLE_DEINTERLACED |
| 2     | W    | 0x00000004 | ENC_EN_PROGRESSIVE_2_I      |
| 3     | W    | 0x00000008 | ENC_EN_DISABLE_ADTS_CRC     |
| 4     | W    | 0x00000100 | ENC_DIS_LATENCY_Q           |
| 4~31  |      | Reserved   |                             |

#### **Description**

- ENC\_EN\_DISABLE\_DEINTERLACED: specific function in chip of B3+ combine H1 HDMI PHY, if user want to input interlaced format and don't need to change format, user can enable this function.
- ENC\_EN\_PROGRESSIVE\_2\_I: change progressive format to interlaced format and output interlaced format, 0 is disable, 1 is enable.
- ENC\_EN\_DISABLE\_ADTS\_CRC: in ADTS audio encoder, it needs to check, use this flag will skip the check and output audio information, 0 is disable, 1 is enable.
- ENC\_DIS\_LATENCY\_Q: user can remove relation of latency and quantity by enable this flag.

0x642 - HALREG\_VIDEO\_CODEC: Encoder format

| Bit # | Туре | Value      | Name        |
|-------|------|------------|-------------|
| 0.1   | W    | 0x00000000 | VIDEO_MPEG2 |
| 0~1   | W    | 0x00000001 | VIDEO_H264  |
| 2~31  |      | Reserved   |             |

#### 0x646 - HALREG\_AUDIO\_CODEC: Audio Encoder format

| Bit # | Туре | Value      | Name              |
|-------|------|------------|-------------------|
|       | W    | 0x00000000 | AUDIO_MP1_L2      |
| 0~1   | W    | 0x00000001 | AUDIO_AAC_LC_ADTS |
|       | W    | 0x00000002 | AUDIO_AC_3        |

|      | W | 0x00000003 | AUDIO_AAC_LC_LATM |
|------|---|------------|-------------------|
| 2~31 |   | Reserved   |                   |

#### **0x2002 - HALREG\_ENCODER\_PMTPID:** set PMT PID in default mode.

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### 0x2003 - HALREG\_VIDEO\_PID: set PID of video PES

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### **0x2004 - HALREG\_AUDIO\_PID:** set PID of audio PES

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

# 4. MUXER register

# 4.1 Mux Related Settings

#### 0x610 - HALREG\_MUX\_PCR\_PID: set PID of PCR

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### 0x611 - HALREG MUX PADDING PID: set PID of padding buffer

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### 0x612 - HALREG MUX BITRATE: set limitation of MUX bitrate

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### 0x630 - HALREG AUXDATA CNTL: use in BML async mode

| Bit # | Туре | Value      | Name            |
|-------|------|------------|-----------------|
| 0~1   | W    | 0x00000001 | AUXDATA_EN_STOP |
| 2~31  |      | Reserved   |                 |

#### **Description**

AUXDATA\_EN\_STOP: if you use BML async mode, you need to write this flag in HALREG, and update BML stream.

#### 0x631 - HALREG\_AUXDATA\_STATUS:

| Bit # | Туре | Value      | Name          |
|-------|------|------------|---------------|
| 0     | R    | 0x00000000 | AUXDATA_IDLE  |
| 1     | R    | 0x00000001 | AUXDATA_ASYNC |
| 2     | R    | 0x00000002 | AUXDATA_SYNC  |
| 3~31  |      | Reserved   | -             |

# **0x632 - HALREG\_AUXDATA\_PACHETNUMS:** BML stream packet

#### numbers

| Bit# | Туре | Value    | Name |
|------|------|----------|------|
| 0~31 |      | Reserved |      |

#### 0x2000 - HALREG\_MUXPSI\_MODE: Produce mode of PSI

| Bit # | Туре | Value      | Name     |
|-------|------|------------|----------|
| 0~2   | W    | 0x00000000 | MUX_PURE |
| 3~31  |      | Reserved   |          |

#### **Description**

MUX\_PURE: set PSI mode as PURE mode, VATEK provide PURE mode, user can set PSI table create by themselves.

# 5. PSI Register

# 5.1 Playload Buffer Register

**0x2100 - HALRANGE\_PLAYLOAD\_START:** register of register PSI/SI table start tag, it's start at 0x2100.

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

# **0x3000 - HALRANGE\_PLAYLOAD\_END:** register of register PSI/SI table end tag, it's end at 0x3000

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### 5.2 PSI Pure Mode

Please follow appendix A

**0x00 - HALOF\_RAWPSI\_TAG:** start and end tag in PSI PURE mode, you need to use start tag when writing new PSI table, and use end tag

#### after finishing table.

|   | Bit# | Туре | Value      | Name             |
|---|------|------|------------|------------------|
| ſ | 0.21 | W    | 0xFF070600 | RAWPSI_EN_TAG    |
|   | 0~31 | W    | 0xFF0706FF | RAWPSI_EN_ENDTAG |

#### **0x01 - HALOF\_RAWPSI\_INTERVAL:** PSI Table Interval Time (ms)

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### 0x02 - HALOF\_RAWPSI\_PACKETS: PSI Table packet size

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### **0x03 – HALOF\_RAWPSI\_DATA:** write PSI table data continuously

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### 5.3 Private PSI table

Please follow appendix B

Private PSI table is the way in PURE mode, it's only can be inserted table after chip start broadcast, but private PSI provide dynamically modify and insert table.

# **0x639 – HALREG\_PRIVATE\_START:** private stream playload start address

| Bit# | Туре | Value | Name |
|------|------|-------|------|
| 0~31 | W    |       |      |

# **0x63A – HALREG\_PRIVATE\_END:** private stream playload end address

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### **0x063B – HALREG\_PRIVATE\_CNTL**: private stream control

| Bit # | Туре | Value      | Name                |
|-------|------|------------|---------------------|
| 0     | W    | 0x80000000 | PRIVATE_EN_CONTINUE |
| 1     | W    | 0x00000001 | PRIVATE_EN_TIMES    |
| 2~31  | W    |            |                     |

#### **Description**

- PRIVATE\_EN\_CONTINUE: when write and read pointer are not equal, user can use this flag to send PSI table to chip.
- PRIVATE\_EN\_TIMES: set PRIVATE\_EN\_TIMES can insert table one time after broadcast start.

# **0x63C – HALREG\_PRIVATE\_WPTR:** Private stream write pointer

(update by user)

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | W    |       |      |

#### **0x63D – HALREG\_PRIVATE\_RPTR:** private stream read pointer

(update by hardware)

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 0~31  | R    |       |      |

# 6. Modulator Register

# **6.1 Modulator Related Settings**

#### 0x601 - HALREG\_BROADCAST\_OUTPUT: Broadcast Output Mode

Register

| Bit # | Туре | Value      | Name              |
|-------|------|------------|-------------------|
| 0     | W    | 0x00000003 | RUNMODE_BROADCAST |
| 1~31  |      | Reserved   |                   |

#### **0x680 - HALREG\_MOD\_MOD:** Modulation Standard Register

| Bit # | Туре | Value      | Name       |
|-------|------|------------|------------|
|       | W    | 0x00000000 | MOD_DVB_T  |
|       | W    | 0x00000001 | MOD_J83A   |
|       | W    | 0x00000002 | MOD_ATSC   |
| 0~3   | W    | 0x00000003 | MOD_J83B   |
| 0~3   | W    | 0x00000004 | MOD_DTMB   |
|       | W    | 0x00000005 | MOD_ISDB_T |
|       | W    | 0x00000006 | MOD_J83C   |
|       | W    | 0x0000007  | MOD_DVB_T2 |
| 4~31  |      | Reserved   |            |

**0x681 - HALREG\_MOD\_IFMODE:** Modulation Switch Register

| Bit # | Туре | Value      | Name             |
|-------|------|------------|------------------|
| 0.1   | W    | 0x00000001 | IFMODE_DISABLE   |
| 0~1   | W    | 0x00000003 | IFMODE_IQ_OFFSET |
| 2~31  |      | Reserved   |                  |

#### **Description**

IFMODE\_IQ\_OFFSET: If you want to use ISDB-T modulator type, you should use IFMODE\_IQ\_OFFSET function. VATEK provide baseband offset function, you can set offset value

0x682 - HALREG\_MOD\_IFFREQ: baseband offset setting register

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
|       | W    |       |      |

#### **Description**

VATEK provide baseband offset function, you can set offset value when you use IFMODE\_IQ\_OFFSET function, it's usually use in ISDB-T modulator type.

**0x683 - HALREG\_MOD\_DACGAIN:** DAC gain setting register

| Bit # | Туре | Value      | Name            |
|-------|------|------------|-----------------|
| 0     | W    | 0x00000000 | DACGAIN_DEFAULT |
| 1~31  | W    |            |                 |

#### Description

VATEK provide the default DACGAIN value, but user also can modify DACGAIN value by using this HAL register.

**0x684 - HALREG\_MOD\_BW\_SB:** Modulator bandwidth or symbol rate setting register

| Bit # | Туре | Value | Name |
|-------|------|-------|------|
| 1~31  | W    |       |      |

# **6.2 DVB-T Settings**

# 0x690 - HALREG\_DVB\_T\_CONSTELLATION: DVB-T Constellation

Register

| Bit # | Туре | Value      | Name        |
|-------|------|------------|-------------|
| 0     | W    | 0x00000000 | DVB_T_QPSK  |
| 1     | W    | 0x00000002 | DVB_T_QAM16 |
| 2     | W    | 0x00000004 | DVB_T_QAM64 |
| 3~31  |      | Reserved   |             |

#### **0x691 - HALREG\_DVB\_T\_FFT:** DVB-T Carrier Mode Register

| Bit # | Туре | Value      | Name        |
|-------|------|------------|-------------|
| 0~1   | W    | 0x00000000 | DVB_T_FFT2K |
|       | W    | 0x00000001 | DVB_T_FFT8K |
| 2~31  |      | Reserved   |             |

#### 0x692 - HALREG\_DVB\_T\_GUARDINTERVAL: DVB-T Guard Interval

Register

| Bit # | Туре | Value      | Name          |
|-------|------|------------|---------------|
|       | W    | 0x00000000 | DVB_T_GI_1_32 |
| 0.1   | W    | 0x0000001  | DVB_T_GI_1_16 |
| 0~1   | W    | 0x00000002 | DVB_T_GI_1_8  |
|       | W    | 0x0000003  | DVB_T_GI_1_4  |
| 2~31  |      | Reserved   |               |

#### **0x693 - HALREG\_DVB\_T\_CODERATE**: DVB-T Code Rate Register

| Bit # | Туре | Value      | Name               |
|-------|------|------------|--------------------|
|       | W    | 0x00000000 | DVB_T_CODERATE_1_2 |
|       | W    | 0x00000001 | DVB_T_CODERATE_2_3 |
| 0~2   | W    | 0x00000002 | DVB_T_CODERATE_3_4 |
|       | W    | 0x00000003 | DVB_T_CODERATE_5_6 |
|       | W    | 0x00000004 | DVB_T_CODERATE_7_8 |
| 3~31  |      | Reserved   |                    |

# 6.3 DVB-C (J83A) Settings

0x690 - HALREG\_J83A\_CONSTELLATION: DVB-C (J83.A)

Constellation Register

| Bit # | Туре | Value      | Name         |
|-------|------|------------|--------------|
|       | W    | 0x00000000 | J83A_QAM16   |
|       | W    | 0x00000001 | J83A_QAM32   |
| 0~2   | W    | 0x00000002 | J83A_QAM64   |
|       | W    | 0x00000003 | J83A_QAM128  |
|       | W    | 0x00000004 | J83A_QAM_256 |
| 3~31  |      | Reserved   |              |

# 6.4 ATSC (8VSB) Settings

# 0x690 - HALREG\_ATSC\_ CONSTELLATION: ATSC (8VSB)

Constellation Register

| Bit # | Туре | Value      | Name      |
|-------|------|------------|-----------|
| 0     | W    | 0x00000000 | ATSC_8VSB |
| 1~31  |      | Reserved   |           |

# 6.5 Clear QAM (J83.B) Settings

#### **0x690 - HALREG\_J83B\_CONSTELLATION:** Clear QAM(J83B)

Constellation Register

| Bit # | Туре | Value      | Name        |
|-------|------|------------|-------------|
| 0.4   | W    | 0x00000001 | J83B_QAM64  |
| 0~1   | W    | 0x00000003 | J83B_QAM256 |
| 2~31  |      | Reserved   |             |

# **6.6 DTMB Settings**

# 0x690 - HALREG\_DTMB\_CONSTELLATION: DTMB Constellation

Register

| Bit # | Туре | Value      | Name       |
|-------|------|------------|------------|
|       | W    | 0x00000000 | DTMB_QPSK  |
| 0.0   | W    | 0x00000001 | DTMB_QAM16 |
| 0~2   | W    | 0x00000002 | DTMB_QAM64 |
|       | W    | 0x00000004 | DTMB_QAM32 |
| 3~31  |      | Reserved   |            |

0x691 - HALREG\_DTMB\_TIME\_INTERLEAVED: DTMB Time

## Interleaved Register

| Bit # | Туре | Value      | Name            |
|-------|------|------------|-----------------|
|       | W    | 0x00000000 | DTMB_TI_DISABLE |
| 0.4   | W    | 0x0000001  | Reserved        |
| 0~1   | W    | 0x00000002 | DTMB_TI_240     |
|       | W    | 0x00000003 | DTMB_TI_720     |
| 2~31  |      | Reserved   |                 |

# **0x692 - HALREG\_DTMB\_CODERATE:** DTMB Code Rate Register

| Bit # | Туре | Value      | Name              |
|-------|------|------------|-------------------|
|       | W    | 0x00000000 | DTMB_CODERATE_0_4 |
| 0~1   | W    | 0x0000001  | DTMB_CODERATE_0_6 |
|       | W    | 0x00000002 | DTMB_CODERATE_0_8 |
| 2~31  |      | Reserved   |                   |

# 0x693 - HALREG\_DTMB\_CARRIERMODE: DTMB Carrier Register

| Bit # | Туре | Value      | Name              |
|-------|------|------------|-------------------|
| 0     | W    | 0x00000000 | DTMB_CARRIER_3780 |
|       | W    | 0x00000001 | DTMB_CARRIER_1    |
| 1~31  |      | Reserved   |                   |

# 0x694 - HALREG\_DTMB\_SYNCFRAME: DTMB Sync Frame Mode

#### Register

| Bit # | Туре | Value      | Name          |
|-------|------|------------|---------------|
|       | W    | 0x00000000 | DTMB_SYNC_420 |
| 0~1   | W    | 0x0000001  | DTMB_SYNC_945 |
|       | W    | 0x00000002 | DTMB_SYNC_595 |
| 2~31  |      | Reserved   |               |

# **6.7 ISDB-T Settings**

# **0x690 - HALREG\_ISDB\_T\_CONSTELLATION: ISDB-T Constellation**

#### Register

| Bit # | Туре | Value      | Name         |
|-------|------|------------|--------------|
|       | W    | 0x00000000 | ISDB_T_DQPSK |
| 0~1   | W    | 0x0000001  | ISDB_T_QPSK  |
| 0~1   | W    | 0x00000002 | ISDB_T_QAM16 |
|       | W    | 0x00000003 | ISDB_T_QAM64 |

| 2~31 |  | Reserved |  |
|------|--|----------|--|
|------|--|----------|--|

# **0x691 - HALREG\_ISDB\_T\_FFT:** ISDB-T Carrier Mode Register

| Bit # | Туре | Value      | Name         |
|-------|------|------------|--------------|
|       | W    | 0x00000000 | ISDB_T_FFT2K |
| 0~1   | W    | 0x00000001 | ISDB_T_FFT8K |
|       | W    | 0x00000002 | ISDB_T_FFT4K |
| 2~31  |      | Reserved   |              |

# **0x692 - HALREG\_ISDB\_T\_GUARDINTERVAL:** ISDB-T Guard Interval

# Register

| Bit # | Туре | Value      | Name           |
|-------|------|------------|----------------|
|       | W    | 0x00000000 | ISDB_T_GI_1_32 |
| 0~1   | W    | 0x0000001  | ISDB_T_GI_1_16 |
| 0~1   | W    | 0x00000002 | ISDB_T_GI_1_8  |
|       | W    | 0x00000003 | ISDB_T_GI_1_4  |
| 2~31  |      | Reserved   |                |

# 0x693 - HALREG\_ISDB\_T\_CODERATE: ISDB-T Code Rate Register

| Bit # | Туре | Value      | Name                |
|-------|------|------------|---------------------|
|       | W    | 0x00000000 | ISDB_T_CODERATE_1_2 |
|       | W    | 0x00000001 | ISDB_T_CODERATE_2_3 |
| 0~2   | W    | 0x00000002 | ISDB_T_CODERATE_3_4 |
|       | W    | 0x00000003 | ISDB_T_CODERATE_5_6 |
|       | W    | 0x00000004 | ISDB_T_CODERATE_7_8 |
| 3~31  |      | Reserved   |                     |

# 0x694 - HALREG\_ISDB\_T\_TIME\_INTERLEAVED: ISDB-T Time

# Interleave Register

| Bit # | Туре | Value      | Name              |
|-------|------|------------|-------------------|
|       | W    | 0x00000000 | ISDB_T_TI_DISABLE |
| 0.1   | W    | 0x0000001  | ISDB_T_TI_MODE1   |
| 0~1   | W    | 0x00000002 | ISDB_T_TI_MODE2   |
|       | W    | 0x00000003 | ISDB_T_TI_MODE3   |
| 2~31  |      | Reserved   |                   |

# 0x695 - HALREG\_ISDB\_T\_FLAGS: ISDB-T Flag Register

| Bit # | Туре | Value      | Name           |
|-------|------|------------|----------------|
| 0.1   | W    | 0x00000001 | ISDB_T_EN_AC_1 |
| 0~1   | W    | 0x00000002 | ISDB_T_EN_AC_2 |

|      | W | 0x00000004 | ISDB_T_EN_EMERGENCY |
|------|---|------------|---------------------|
| 2~31 |   | Reserved   |                     |

# 6.8 J83.C Settings

# 0x690 - HALREG\_J83C\_CONSTELLATION: J83.C Constellation

#### Register

| Bit # | Туре | Value      | Name        |
|-------|------|------------|-------------|
| 0     | W    | Reserved   |             |
| 1     | W    | 0x00000002 | J83C_QAM64  |
| 2     | W    | 0x00000004 | J83C_QAM256 |
| 3~31  |      | Reserved   |             |

# 6.9 DVB-T2 Settings

#### **0x691 - HALREG\_DVB\_T2\_FLAGS:** DVB-T2 Control Register

| Bit # | Туре | Value      | Name                        |
|-------|------|------------|-----------------------------|
| 0     | W    | 0x00000001 | T2EN_EXTEND_CARRIER_MODE    |
| 1     | W    | 0x00000002 | T2EN_CONSTELLATION_ROTATION |
| 2     | W    | 0x00000004 | T2EN_INPUT_TS_HEM           |
| 3     | W    | 0x00000008 | T2EN_DELETE_NULL_PACKET     |
| 4     | W    | 0x00000010 | T2EN_VBR_CODING             |
| 5     | W    | 0x00000020 | T2EN_TIME_INTERVAL          |
| 6~31  |      | Reserved   |                             |

# **0x692 - HALREG\_DVB\_T2\_ISSY:** DVB-T2 ISSY Register

| Bit # | Туре | Value      | Name            |
|-------|------|------------|-----------------|
|       | W    | 0x00000000 | T2_ISSY_DISABLE |
| 0~1   | W    | 0x00000002 | T2_ISSY_SHORT   |
|       | W    | 0x00000003 | T2_ISSY_LONG    |
| 2~31  |      | Reserved   |                 |

# 0x693 - HALREG\_DVB\_T2\_NIT: DVB-T2 NIT Register

| Bit # | Туре | Value      | Name           |
|-------|------|------------|----------------|
| 0     | W    | 0x00000000 | T2_NTI_DISABLE |
| 1~31  |      | Reserved   |                |

# 0x694 - HALREG\_DVB\_T2\_L1\_CONSTELLATION: DVB-T2 L1

#### Constellation Register

| Bit # | Туре | Value      | Name        |
|-------|------|------------|-------------|
|       | W    | 0x00000000 | T2_L1_BPSK  |
| 0.0   | W    | 0x00000001 | T2_L1_QPSK  |
| 0~2   | W    | 0x00000002 | T2_L1_QAM16 |
|       | W    | 0x00000003 | T2_L1_QAM64 |
| 3~31  |      | Reserved   |             |

# 0x695 - HALREG\_DVB\_T2\_PLP\_CONSTELLATION: DVB-T2 PLP

# Constellation Register

| Bit # | Туре | Value      | Name          |
|-------|------|------------|---------------|
|       | W    | 0x00000000 | T2_PLP_QPSK   |
| 0.2   | W    | 0x0000001  | T2_PLP_QAM16  |
| 0~2   | W    | 0x00000002 | T2_PLP_QAM64  |
|       | W    | 0x00000003 | T2_PLP_QAM256 |
| 3~31  |      | Reserved   |               |

## 0x696 - HALREG\_DVB\_T2\_FFT: DVB-T2 Carrier Mode Register

| Bit # | Туре | Value      | Name       |
|-------|------|------------|------------|
|       | W    | 0x00000000 | T2_FFT_1K  |
|       | W    | 0x0000001  | T2_FFT_2K  |
| 0.0   | W    | 0x00000002 | T2_FFT_4K  |
| 0~2   | W    | 0x0000003  | T2_FFT_8K  |
|       | W    | 0x0000004  | T2_FFT_16K |
|       | W    | 0x0000005  | T2_FFT_32K |
| 3~31  |      | Reserved   |            |

# 0x697 - HALREG\_DVB\_T2\_CODERATE: DVB-T2 Code Rate Register

| Bit # | Туре | Value      | Name            |
|-------|------|------------|-----------------|
|       | W    | 0x00000000 | T2_CODERATE_1_2 |
|       | W    | 0x0000001  | T2_CODERATE_3_5 |
|       | W    | 0x00000002 | T2_CODERATE_2_3 |
| 0.0   | W    | 0x0000003  | T2_CODERATE_3_4 |
| 0~2   | W    | 0x0000004  | T2_CODERATE_4_5 |
|       | W    | 0x0000005  | T2_CODERATE_5_6 |
|       | W    | 0x0000006  | T2_CODERATE_1_3 |
|       | W    | 0x0000007  | T2_CODERATE_2_5 |
| 3~31  |      | Reserved   |                 |

# 0x698 - HALREG\_DVB\_T2\_GUARDINTERVAL: DVB-T2 Guard Interval

Register

| Bit # | Туре | Value      | Name         |
|-------|------|------------|--------------|
|       | W    | 0x00000000 | T2_GI_1_32   |
|       | W    | 0x0000001  | T2_GI_1_16   |
|       | W    | 0x00000002 | T2_GI_1_8    |
| 0~2   | W    | 0x0000003  | T2_GI_1_4    |
|       | W    | 0x0000004  | T2_GI_1_128  |
|       | W    | 0x0000005  | T2_GI_19_128 |
|       | W    | 0x00000006 | T2_GI_19_256 |
| 3~31  |      | Reserved   |              |

# 0x699 - HALREG\_DVB\_T2\_PILOTPATTERN: DVB-T2 Pilot Pattern Register

| Bit # | Туре | Value      | Name    |
|-------|------|------------|---------|
|       | W    | 0x00000000 | T2_PP_1 |
|       | W    | 0x0000001  | T2_PP_2 |
|       | W    | 0x00000002 | T2_PP_3 |
| 0.0   | W    | 0x0000003  | T2_PP_4 |
| 0~2   | W    | 0x0000004  | T2_PP_5 |
|       | W    | 0x00000005 | T2_PP_6 |
|       | W    | 0x00000006 | T2_PP_7 |
|       | W    | 0x00000007 | T2_PP_8 |
| 3~31  |      | Reserved   |         |

# **0x69A - HALREG\_DVB\_T2\_FECTYPE:** DVB-T2 FEC Frame Length Register

| Bit # | Туре | Value      | Name         |
|-------|------|------------|--------------|
| 0     | W    | 0x00000000 | T2_FEC_16200 |
| 0     | W    | 0x00000001 | T2_FEC_64800 |
| 1~31  |      | Reserved   |              |

#### 0x69B - HALREG\_DVB\_T2\_NID: DVB-T2 NID Register

| Bit # | Туре | Value    | Name |
|-------|------|----------|------|
| 1~31  |      | Reserved |      |

## 0x69C - HALREG\_DVB\_T2\_SID: DVB-T2 SID Register

| Bit # | Туре | Value    | Name |
|-------|------|----------|------|
| 1~31  |      | Reserved |      |

#### 0x69D - HALREG\_DVB\_T2\_FECBN: DVB-T2 FECBN Register

| Bit# | Type Value | Name |
|------|------------|------|
|------|------------|------|

| 1~31 | Reserved |
|------|----------|
|------|----------|

#### 0x69E - HALREG\_DVB\_T2\_SBN: DVB-T2 SBN Register

| Bit# | Туре | Value    | Name |
|------|------|----------|------|
| 1~31 |      | Reserved |      |

# 7. Broadcast Related Registers

## 7.1 General Settings

0x600 - HALREG\_SERVICE\_BASE\_CNTL: Broadcast Control Register

| Bit # | Туре | Value      | Name                     |
|-------|------|------------|--------------------------|
| 0     | W    | 0x0000001  | BASE_CMD_START           |
| 1     | W    | 0x00000002 | BASE_CMD_STOP            |
| 2     | W    | 0x0000004  | BASE_CMD_TEST_START_SINE |
| 3     | W    | 0x00000008 | BASE_CMD_TEST_START      |
| 2~7   |      | Reserved   |                          |
| 8     | W    | 0x00000100 | BASE_CMD_REBOOT          |
| 9     | W    | 0x00000200 | BASE_CMD_REBOOT_RESCURE  |
| 10~11 |      | Reserved   |                          |
| 12    | W    | 0x00001000 | RFMIXER_CMD_START        |
| 13    | W    | 0x00002000 | RFMIXER_CMD_STOP         |
| 14~31 |      | Reserved   |                          |

#### **Description**

- BASE CMD START: service start command.
- BASE\_CMD\_STOP: service stop command.
- BASE CMD TEST START SINE: use sine wave starting.
- BASE CMD TEST START: test mode start.
- BASE\_CMD\_REBOOT: software reset command using with BASE\_CMD\_REBOOT\_RESCURE, if user want to reset chip by software reset, can using this command without chip fail.
- BASE\_CMD\_REBOOT\_RESCURE: software reset command using with BASE\_CMD\_REBOOT, if user want to reset chip by software reset, can using this command without chip fail.
- RFMIXER CMD START: RF start command, control by VATek chip.
- RFMIXER\_CMD\_STOP: RF start command, control by VATek chip.

# 7.2 RF Related Settings (For VATEK R2 Control)

0x1200 - HALREG\_RF\_COM\_STATUS: R2 Status Register

| Bit # | Туре | Value      | Name             |  |  |  |
|-------|------|------------|------------------|--|--|--|
| 0     | R    | 0x0000001  | RF_STATUS_IDLE   |  |  |  |
| 1     | R    | 0x00000002 | RF_STATUS_ACTIVE |  |  |  |
| 2~30  |      | Reserved   |                  |  |  |  |
| 31    | R    | 0x80000000 | RF_STATUS_FAIL   |  |  |  |

# 0x1202 - HALREG\_RF\_COM\_FREQ: R2 Frequency Register

| Bit # | Туре | Value    | Name |
|-------|------|----------|------|
| 0     | W    |          | KHz  |
| 1~31  |      | Reversed |      |

# Description

User only need to set RF frequency and write RF start command, RF will start output.

# **Appendix**

# A. Register PSI/SI table by using PSI PURE mode

Register table during 0x2100 to 0x3000 , refer 5.2 。



| PLAYLOAD RANGE                                          |                                                         |                                                         |                 |  |  |  |  |  |  |
|---------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------|-----------------|--|--|--|--|--|--|
| PSI TABLE                                               | PSI TABLE                                               | PSI TABLE                                               | oj.             |  |  |  |  |  |  |
| RAWPSI_EN_TAG PSI Interval PSI Packet Number PSI Packet | RAWPSI_EN_TAG PSI Interval PSI Packet Number PSI Packet | RAWPSI_EN_TAG PSI Interval PSI Packet Number PSI Packet | RAWPSI_EN_ENDTA |  |  |  |  |  |  |

| Syntax                                                                   | Bits |
|--------------------------------------------------------------------------|------|
| PSITABLE_REGISTER() {                                                    |      |
| for (i=0; i <table_number; i++)="" td="" {<=""><td></td></table_number;> |      |
| RAWPSI_EN_TAG                                                            | 32   |
| HALOF_RAWPSI_INTERVAL                                                    | 32   |
| HALOF_RAWPSI_PACKETS                                                     | 32   |
| HALOF_RAWPSI_DATA                                                        | 32*N |
| }                                                                        |      |
| RAWPSI_EN_ENDTAG                                                         | 32   |
| }                                                                        |      |
|                                                                          |      |

Table\_Number: number of register PSI/SI table , 16 is maximum 。

RAWPSI\_EN\_TAG: start tag when registering PSI/SI table •

HALOF\_RAWPSI\_INTERVAL: interval of transport table ∘

HALOF\_RAWPSI\_PACKETS: packet number of PSI/SI table , each packet

max is 188 Bytes •

HALOF\_RAWPSI\_DATA: data of register PSI/SI ∘

RAWPSI\_EN\_ENDTAG: end tag of register PSI/SI -

# B. Insert PSI/SI table by using PSI PURE mode

Insert table during 0x2100 to 0x3000, refer 5.3



# C. RF start flow (for VATek R2)

